<template>
    <div class="container">
        <div class="header">我的订单</div>
        <van-tabs v-model:active="active" @click-tab="onClickTab">
            <van-tab title="全部" name=""></van-tab>
            <van-tab title="待支付" name="1"></van-tab>
            <van-tab title="待服务" name="2"></van-tab>
            <van-tab title="已完成" name="3"></van-tab>
            <van-tab title="已取消" name="4"></van-tab>
        </van-tabs>
        <van-row v-for="item in order" :key="item.out_trade_no" @click="goDetail(item)">
            <van-col span="5">
                <van-image width="50" height="50" redius="5" :src="item.serviceImg"></van-image>
            </van-col>
            <van-col span="14">
                <div class="text1">{{ item.service_name }}</div>
                <div class="text2">
                    <div>{{ item.hospital_name }}</div>
                    <di>预约时间：{{ item.starttime }}</di>
                </div>
            </van-col>
            <van-col span="5" class="text2" :style="{ color: colorMap[item.trade_state] }">
                {{ item.trade_state }}
                <counter :second="item.timer" v-if="item.trade_state === '待支付'"></counter>
            </van-col>
        </van-row>
        <div class="bottom-text">没有更多了</div>
    </div>
</template>

<script setup>
import { ref, getCurrentInstance, onMounted } from 'vue';
import { useRouter } from 'vue-router';
import counter from '../../components/counter.vue';

const { proxy } = getCurrentInstance();
const active = ref("");
// 获取订单列表
const order = ref([]);
const getOrderList = async (state) => {
    const { data } = await proxy.$api.orderList({ state });
    data.data.forEach(item => {
        item.timer = item.order_start_time + 7200000 - Date.now();
    });
    order.value = data.data;
};
// 初始化
onMounted(() => {
    getOrderList('');
});
const colorMap = {
    '待支付': '#ffa200',
    '待服务': '#1da6fd',
    '已完成': '#21c521',
};
const onClickTab = (item) => {
    getOrderList(item.name);
};

// 跳转详情
const router = useRouter();
const goDetail = (item) => {
    router.push(`/detail?oid=${item.out_trade_no}`);
};

</script>

<style scoped lang="less">
.container {
    background-color: #f0f0f0;
    height: 100vh;
}

.header {
    background-color: #fff;
    line-height: 40px;
    text-align: center;
}

.van-row {
    background-color: #fff;
    padding: 10px;
    margin: 5px;
    border-radius: 5px;

    .text1 {
        font-size: 16px;
        line-height: 25px;
        font-weight: bold;
    }

    .text2 {
        font-size: 14px;
        line-height: 20px;
        color: #999999;
    }
}

.bottom-text {
    line-height: 50px;
    text-align: center;
    color: #999999;
}
</style>